package com.ifast.sys.config;

import java.util.List;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.format.FormatterRegistry;
import org.springframework.http.converter.HttpMessageConverter;
import org.springframework.validation.MessageCodesResolver;
import org.springframework.validation.Validator;
import org.springframework.web.method.support.HandlerMethodArgumentResolver;
import org.springframework.web.method.support.HandlerMethodReturnValueHandler;
import org.springframework.web.servlet.HandlerExceptionResolver;
import org.springframework.web.servlet.config.annotation.AsyncSupportConfigurer;
import org.springframework.web.servlet.config.annotation.ContentNegotiationConfigurer;
import org.springframework.web.servlet.config.annotation.CorsRegistry;
import org.springframework.web.servlet.config.annotation.DefaultServletHandlerConfigurer;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.PathMatchConfigurer;
import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
import org.springframework.web.servlet.config.annotation.ViewControllerRegistry;
import org.springframework.web.servlet.config.annotation.ViewResolverRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

import com.ifast.sys.filter.CsrfTokenInterceptor;
import com.ifast.sys.filter.FormTokenInterceptor;
import com.ifast.sys.filter.SameUrlDataInterceptor;
import com.ifast.sys.filter.token.CsrfAnnotTokenInterceptor;

@Configuration
public class WebSecurityConfig  implements WebMvcConfigurer {

    @Bean
   public FormTokenInterceptor getSecurityInterceptor() {
        return new FormTokenInterceptor();
    }

    @Bean
    public SameUrlDataInterceptor getInterceptor(){
        return new SameUrlDataInterceptor();
    }

    @Bean
    public CsrfAnnotTokenInterceptor getAnnotTokenInterceptor(){
        return new CsrfAnnotTokenInterceptor();
    }
    
    @Bean
    public CsrfTokenInterceptor getTokenInterceptor(){
        return new CsrfTokenInterceptor();
    }
    
    
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(getSecurityInterceptor()).addPathPatterns("/sys/**");
        registry.addInterceptor(getInterceptor()).addPathPatterns("/**");
        registry.addInterceptor(getAnnotTokenInterceptor()).addPathPatterns("/**");
    }

	@Override
	public void addArgumentResolvers(List<HandlerMethodArgumentResolver> arg0) {}

	@Override
	public void addCorsMappings(CorsRegistry registry) {
		registry.addMapping("/hessian/**").allowCredentials(true).maxAge(3600);
	}

	@Override
	public void addFormatters(FormatterRegistry arg0) {}

	@Override
	public void addResourceHandlers(ResourceHandlerRegistry arg0) {}

	@Override
	public void addReturnValueHandlers(List<HandlerMethodReturnValueHandler> arg0) {}

	@Override
	public void addViewControllers(ViewControllerRegistry arg0) {}

	@Override
	public void configureAsyncSupport(AsyncSupportConfigurer arg0) {}

	@Override
	public void configureContentNegotiation(ContentNegotiationConfigurer arg0) {}

	@Override
	public void configureDefaultServletHandling(DefaultServletHandlerConfigurer arg0) {}

	@Override
	public void configureHandlerExceptionResolvers(List<HandlerExceptionResolver> arg0) {}

	@Override
	public void configureMessageConverters(List<HttpMessageConverter<?>> arg0) {}

	@Override
	public void configurePathMatch(PathMatchConfigurer arg0) {}

	@Override
	public void configureViewResolvers(ViewResolverRegistry arg0) {}

	@Override
	public void extendHandlerExceptionResolvers(List<HandlerExceptionResolver> arg0) {}

	@Override
	public void extendMessageConverters(List<HttpMessageConverter<?>> arg0) {}

	@Override
	public MessageCodesResolver getMessageCodesResolver() {return null;}

	@Override
	public Validator getValidator() {return null;}
}